package leetcode.editor.cn;
/**
  * 题目Id：209
  * 题目：长度最小的子数组
  * 日期：2024-03-07 21:40:48
*/
//给定一个含有 n 个正整数的数组和一个正整数 target 。 
//
// 找出该数组中满足其总和大于等于 target 的长度最小的 连续子数组 [numsl, numsl+1, ..., numsr-1, numsr] ，并返
//回其长度。如果不存在符合条件的子数组，返回 0 。 
//
// 
//
// 示例 1： 
//
// 
//输入：target = 7, nums = [2,3,1,2,4,3]
//输出：2
//解释：子数组 [4,3] 是该条件下的长度最小的子数组。
// 
//
// 示例 2： 
//
// 
//输入：target = 4, nums = [1,4,4]
//输出：1
// 
//
// 示例 3： 
//
// 
//输入：target = 11, nums = [1,1,1,1,1,1,1,1]
//输出：0
// 
//
// 
//
// 提示： 
//
// 
// 1 <= target <= 10⁹ 
// 1 <= nums.length <= 10⁵ 
// 1 <= nums[i] <= 10⁵ 
// 
//
// 
//
// 进阶： 
//
// 
// 如果你已经实现 O(n) 时间复杂度的解法, 请尝试设计一个 O(n log(n)) 时间复杂度的解法。 
// 
//
// Related Topics 数组 二分查找 前缀和 滑动窗口 👍 2066 👎 0


public class MinimumSizeSubarraySum {
    public static void main(String[] args) {
        Solution solution = new MinimumSizeSubarraySum().new Solution();
        solution.minSubArrayLen(7,new int[] {2,3,1,2,4,3});
        
        System.out.println("Hello world");
    }

    //leetcode submit region begin(Prohibit modification and deletion)
class Solution {
//    public int minSubArrayLen(int target, int[] nums) {
//        /**
//         * 暴力破解方法
//         */
//        int minLen=Integer.MAX_VALUE;
//        for (int i = 0; i < nums.length; i++) {
//            int sum=0;
//            for(int j=i;j<nums.length;j++){
//                sum=sum+nums[j];
//                if(sum>=target){
//                    minLen=Math.min(minLen,j-i+1);
//                }
//            }
//
//        }
//        return minLen==Integer.MAX_VALUE?0:minLen;
//
//
//    }

        public int minSubArrayLen(int target, int[] nums) {

            int minLen=0;
            //定义存储

            for (int i = 0; i < nums.length; i++) {
                int sum=0;
                for(int j=i;j<nums.length;j++){
                    sum=sum+nums[j];
                    if(sum>=target){
                        minLen=Math.min(minLen,j-i+1);
                    }
                }

            }
            return minLen==Integer.MAX_VALUE?0:minLen;


        }
}
//leetcode submit region end(Prohibit modification and deletion)

} 
